# Fayoum University Faculty Of Engineering



# Single Cycle Processor

# **Computer Architecture**

**Group's member:** 

Ahmed Osama EL-Sayed
Esmail Abdel-Rahman
Hosam Ayoub Bayoumi
Hesham Yasser Ahmed

## The description of each component:

### 1. Register File

Array of processor registers which are temporary storage locations inside the CPU that hold data and addresses. The register file is the component that contains all the general-purpose registers of the microprocessor. A few CPUs also place special registers such as the PC and the status register in the register file. Other CPUs keep them separate.



### 2. ALU

An arithmetic-logic unit (ALU) is the part of a computer processor (CPU) that carries out arithmetic and logic operations on the operands in computer instruction words. The ALU does the following operations: R-Type (AND- OR- XOR- EQV- Add- Sub- SIt- SEQ), I-Type(Andl-ORI- XORI- EQVI- AddI- SLTI- SEQI- SLL- SRL- ROR- BEQ- BNE- LW- SW), B-Type (BEQZ- BNEZ- BLTZ- BGEZ- BGTZ- BLEZ- JR- JALR- SET- SSET) and J-Type (J- JAL).





#### 3. Control Unit

The control unit of the central processing unit regulates and integrates the operations of the computer. It selects and retrieves instructions from the main memory in proper sequence and interprets them so as to activate the other functional elements of the system at the appropriate moment.

|         | operation | F    | op-code | ALU-OP | add/sub | rea-dest | REG-WRITE | rea-scr | M-Write | M-Read | MemToRea | pcnext | branch | b-all | i-src |
|---------|-----------|------|---------|--------|---------|----------|-----------|---------|---------|--------|----------|--------|--------|-------|-------|
| no<br>1 |           | 0    | 0x00    | 0x00   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 2       |           | 1    | 0x00    | 0x00   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | x      | XXX   | 0     |
| 3       |           | 2    | 0x00    | 0x00   | 11      | 01       | i         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 4       |           | 3    | 0x00    | 0x00   | 11      | 01       | i         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 5       |           | 0    | 0x01    | 0x01   | 00      | 01       | 1         | 0       | Ö       | 0      | 00       | 00     | X      | XXX   | 0     |
| 6       |           | 1    | 0x01    | 0x01   | 01      | 01       | i         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 7       |           | 2    | 0x01    | 0x01   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 8       | sea       | 3    | 0x01    | 0x01   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| no      | operation |      | op-code | ALU-OP | add/sub | rea-dest | REG-WRITE | reg-scr | M-Write | M-Read | MemToRea | pcnext | branch | b-all | i-src |
| 9       | andi      | ХX   | 0x04    | 0x04   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | х      | XXX   | 0     |
| 10      | ori       | ХX   | 0x05    | 0x05   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | х      | XXX   | 0     |
| 11      | xori      | ХX   | 0x06    | 0x06   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | х      | XXX   | 0     |
| 12      |           | XX   | 0x07    | 0x07   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 13      | addi      | ХX   | 0x08    | 0x08   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 14      | slti      | ХX   | 0x09    | 0x09   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | х      | XXX   | 0     |
| 15      | seqi      | XX   | 0x0A    | 0x0A   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 16      |           | XX   | 0x0B    | 0x0B   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 17      |           | XX   | 0x0C    | 0x0C   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 18      |           | XX   | 0x0D    | 0x0D   | 11      | 01       | 1         | 0       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 19      |           | XX   | 0x0E    | 0x0E   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 000   | 0     |
| 20      |           | XX   | 0x0F    | 0x0F   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 001   | 0     |
| 21      |           | XX   | 0x10    | 0x10   | 11      | 01       | 1         | X       | 0       | 1      | 01       | 00     | X      | XXX   | 0     |
| 22      |           | XX   | 0x11    | 0x11   | 11      | XX       | 0         | X       | 1       | 0      | XX       | 00     | X      | XXX   | 0     |
| no      |           |      | op-code | ALU-OP | add/sub | reg-dest | REG-WRITE | reg-scr | M-Write | M-Read | MemToReg | pcnext | branch | b-all | j-src |
| 23      |           | XX   | 0x14    | 0x14   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 010   | 0     |
| 24      |           | XX   | 0x15    | 0x15   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 011   | 0     |
| 25      |           | XX   | 0x16    | 0x16   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 100   | 0     |
| 26      |           | XX   | 0x17    | 0x17   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 101   | 0     |
| 27      | bgtz      | XX   | 0x18    | 0x18   | 11      | XX       | 0         | 11      | 0       | 0      | XX       | 10     | 1      | 110   | 0     |
| 28      |           | XX   | 0x19    | 0x19   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 10     | 1      | 111   | 0     |
| 29      |           | XX   | 0x1A    | 0x1A   | 11      | XX       | 0         | 1       | 0       | 0      | XX       | 11     | X      | XXX   | 0     |
| 30      |           | XX   | 0x1B    | 0x1B   | 11      | XX       | 1         | 11      | 0       | 0      | 10       | 11     | X      | XXX   | 1     |
| 31      |           | XX   | 0x1C    | 0x1C   | 11      | 01       | 1         | X       | 0       | 0      | 00       | 00     | X      | XXX   | 0     |
| 32      |           | XX   | 0x1D    | 0x1D   | 11      | 01       | 1         | 1       | 0       | 0      | 00       | 00     | Х      | XXX   | 0     |
| no      | operation |      | op-code | ALU-OP | add/sub | reg-dest | REG-WRITE | reg-scr | M-Write | M-Read | MemToReg | pcnext | branch | b-all | j-src |
| 33      |           | _xx_ | 0x1E    | X      | 11      | XX       | 0         | X       | 0       | 0      | XX       | 01     | X      | XXX   | 0     |
| 34      | jal       | XX   | 0x1F    | X      | 11      | XX       | 1         | X       | 0       | 0      | 10       | 01     | X      | XXX   | 1     |



#### 4. Data Path

A data-path is a collection of functional units, such as arithmetic logic unit or multipliers that perform data processing operations, registers and buses. Along with the control unit it composes the central processing unit. Simply the control unit receives external instructions or commands which it converts to into a sequence of control signals that the control unit applies to the data-path to implement a sequence of register transfer level operations.

